forked from niklasso/minisat
-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Iterative partitioning #134
Open
conp-solutions
wants to merge
40
commits into
master
Choose a base branch
from
iterative-partitioning
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
conp-solutions
force-pushed
the
iterative-partitioning
branch
2 times, most recently
from
April 25, 2023 21:04
0d507d3
to
f199d2d
Compare
... to speedup the build, and avoid unnecessary rebuilds. Signed-off-by: Norbert Manthey <[email protected]>
We want to build different MergeSat-based Dockerfiles. Hence, this change introduce configurability. This way, multiple docker images can be build from the same Dockerfile. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Basic type to maintain a partition tree. Signed-off-by: Norbert Manthey <[email protected]>
Implement helper methods to be able to work with the partition tree. Signed-off-by: Norbert Manthey <[email protected]>
Support starting partitioning after some syncs. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Implement the first stubs to support partitioning the search space next. Signed-off-by: Norbert Manthey <[email protected]>
Add a separate method to handle UNSAT cases when a solver returns from solving a partition. Note: the actual relevant code is not added yet, this change only moves the exception into a better place for future iteration. Signed-off-by: Norbert Manthey <[email protected]>
... so that controlling their allocation is properly jailed. Signed-off-by: Norbert Manthey <[email protected]>
... based on the position of each node on the path to the root among its siblings. The signature can be used to print traces during debugging, or to print the actual partition tree. Signed-off-by: Norbert Manthey <[email protected]>
This method allows to load the assumptions for a solver when it is asked to solver a partition of the search space. Signed-off-by: Norbert Manthey <[email protected]>
Furthermore, wrap assigning a node to a thread in a separate method to have a single location to control this change. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
This change adds the work in progress state for solving formulas in parallel, while maintaining and assigning partitions to threads. Note: there is no option to enable or disable this functionality yet. Furthermore, the solver might be very verbose at this point. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
conp-solutions
force-pushed
the
iterative-partitioning
branch
2 times, most recently
from
April 28, 2023 18:32
8c6548d
to
94d619f
Compare
Note: this commit should not be required in case all other commits get formatting applied. Signed-off-by: Norbert Manthey <[email protected]>
... so that we do not have any left-overs later on. Signed-off-by: Norbert Manthey <[email protected]>
... because otherwise there should not be a global conflict. Signed-off-by: Norbert Manthey <[email protected]>
When a partition is solved, the solver enters sync with l_False. However, we want to be able to assign this status back to l_Undef, as we might assign a new partition to the solver. Signed-off-by: Norbert Manthey <[email protected]>
The initial code did not iterate in the tree. Furthermore, the status of the solver, as well as the conflict of the involved solver need to be reset once we collect an unsatisfiable node. Note: this change could also be merged in the previous commit of this function. Signed-off-by: Norbert Manthey <[email protected]>
When a solver finds a conflict, we need to process it immediately. Otherwise, the l_False status would be propagated back to search, which then will terminate with UNSAT; leading to a wrong locking order and a deadlock. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
... instead of waiting for 1000 syncs by default. Signed-off-by: Norbert Manthey <[email protected]>
... as partitioning then uses assumptions, and the involved variables might have been eliminated by the time. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
When we find UNSAT during sync, e.g. by receiving clauses, make sure this status is propagated to the thread status as well, as this is used to then terminate search with the proper status as well. Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
conp-solutions
force-pushed
the
iterative-partitioning
branch
from
April 28, 2023 19:04
94d619f
to
9534f3d
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
No description provided.